*, *:after, *:before {
box-sizing: border-box;
}
body {
margin: 0;
}
.game-wrapper {
width: 100%;
height: 100vh;
display: flex;
flex-direction: column;
overflow: hidden;
}
.game-container {
flex: 1;
background: url("https://bhckids.org/wp-content/uploads/2015/04/background.jpg") no-repeat;
background-size: cover;
background-position: center center;
display: flex;
width: 100%;
justify-content: center;
position: relative;
z-index: 500;
}
.game-container:after {
content: "";
position: absolute;
left: 50%;
transform: translateX(-50%);
height: 100%;
border-left: 2px dashed #555;
}
.game-col {
flex: 1;
display: flex;
align-items: flex-end;
max-width: 600px;
}
.computer-col {
transform: rotateY(180deg);
max-width: 600px;
}
.computer-col .cannon {
transition: 1s ease-in;
}
.computer-col .cannon .pipe {
transition: 1s ease-in;
}
.computer-col .cannon .wheel {
transition: 1s ease-in;
}
.cannon {
position: relative;
z-index: 100;
transform: translateX(5cm);
}
.cannon:before {
content: "";
z-index: 5;
position: absolute;
height: 200px;
border-right: 1px dashed #fff;
left: 131px;
top: 50%;
border-radius: 50%;
transform: translateY(-50%);
}
.cannon .pipe {
width: 160px;
height: 40px;
margin-bottom: 50px;
background: linear-gradient(to right, #333 1%, #333 35%, #222 36%, #222 36%, #222 41%, #333 41%, #333 100%);
border-radius: 0 50px 50px 0;
position: relative;
transform-origin: right center;
}
.cannon .pipe:after {
content: "";
position: absolute;
width: 15px;
height: 50px;
background: #222;
border: 2px solid #333;
border-radius: 50px;
top: 50%;
transform: translateY(-50%);
}
.cannon .pipe:before {
content: "";
position: absolute;
width: 120px;
height: 60px;
background: linear-gradient(to right, #333 1%, #333 35%, #222 36%, #222 36%, #222 41%, #333 41%, #333 100%);
border-radius: 50% 50px 50px 50%;
top: 50%;
transform: translateY(-50%);
left: 50%;
}
.cannon .wheel {
position: absolute;
width: 100px;
height: 100px;
color: #222;
border: 10px solid currentColor;
border-radius: 50%;
bottom: 0;
right: -21px;
background: linear-gradient(to bottom, #752f16 93%, #1c0701 94%);
background-size: 100% 10px;
}
.cannon .wheel:after {
content: "";
position: absolute;
width: 35px;
background: #111;
height: 35px;
left: 50%;
top: 50%;
border-radius: 50%;
transform: translate(-50%, -50%);
}
.level {
width: 60vw;
position: absolute;
right: 0;
top: 50%;
transform: translateY(-50%);
}
.ball {
width: 30px;
height: 30px;
background: #333;
border-radius: 50%;
position: absolute;
top: 50%;
transform: translateY(-50%);
left: 0;
}
.ball:after {
content: "";
position: absolute;
width: 100%;
height: 100%;
background: #333;
border-radius: 50%;
left: 0;
top: 0;
}
.cm .ball:before {
content: "";
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%, -40%);
width: 300px;
height: 250px;
background: url(https://www.onlygfx.com/wp-content/uploads/2017/06/comic-boom-explosion-2-1.png) no-repeat;
background-size: 100% auto;
z-index: -1;
opacity: 0;
}
.fire {
-webkit-animation: fire 0.3s ease-in-out;
animation: fire 0.3s ease-in-out;
}
.defended .fire .ball:before {
transition: 0.2s 0.3s linear;
opacity: 1;
}
.wheel-handle {
position: absolute;
background: #fff url("https://cdn.onlinewebfonts.com/svg/img_520243.png") no-repeat;
background-size: 100% auto;
background-position: center;
width: 40px;
height: 40px;
left: 111px;
top: 19px;
border-radius: 50%;
z-index: 10;
cursor: w-resize;
opacity: 0.8;
}
.level-handle {
position: absolute;
background: #6200EA;
width: 40px;
height: 40px;
left: 140%;
top: 50%;
border-radius: 50%;
transform: translateY(-50%);
z-index: 54;
color: #fff;
text-align: center;
line-height: 36px;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
cursor: -webkit-grab;
cursor: grab;
border: 2px solid #fff;
}
.level-handle:after, .level-handle:before {
content: "";
position: absolute;
left: 50%;
transform: translateX(-50%);
border: 10px solid transparent;
border-bottom-color: #fff;
top: -27px;
}
.level-handle:after {
border: 10px solid transparent;
border-top-color: #fff;
top: 44px;
}
.level-handle:active, .level-handle:focus {
cursor: -webkit-grabbing;
cursor: grabbing;
}
.level-monitor {
position: absolute;
background: #fff;
width: 40px;
height: 40px;
left: 130%;
top: 50%;
border-radius: 50%;
transform: translateY(-50%) rotateY(180deg);
z-index: 54;
color: #333;
text-align: center;
line-height: 36px;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
border: 2px dashed #777;
}
.countdown {
position: fixed;
z-index: 5000;
width: 100px;
height: 100px;
background: #fff;
color: #00897B;
font-size: 30px;
font-family: arial;
top: 10px;
left: 50%;
transform: translateX(-50%);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
border: 10px solid #00897B;
}
.road {
background: #E9B7A4;
height: 100px;
position: relative;
}
.scale {
display: flex;
position: absolute;
left: 50%;
top: 2px;
transform: translateX(-50%);
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.scale-point {
list-style: none;
margin: 0;
padding: 0;
display: flex;
}
.scale-point.mirror {
flex-direction: row-reverse;
}
.scale-point li {
width: 1cm;
position: relative;
padding-top: 20px;
}
.scale-point li .unit {
display: inline-block;
position: relative;
transform: translateX(-50%);
}
.scale-point li:before, .scale-point li:after {
content: "";
position: absolute;
left: 0;
top: 0;
width: 1px;
height: 17px;
background: #000;
transform: translateX(-50%);
}
.scale-point li:after {
left: 50%;
height: 12px;
color: #555;
box-shadow: 0.1cm 0, 0.2cm 0, 0.3cm 0, 0.4cm 0, -0.1cm 0, -0.2cm 0, -0.3cm 0, -0.4cm 0, 0.1cm 0, 0.2cm 0, 0.3cm 0, 0 2px #000;
}
@-webkit-keyframes fire {
50% {
left: 5px;
}
}
@keyframes fire {
50% {
left: 5px;
}
}